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Preface 



This document is an addendum to Chapter 4 (Programming) of the 
DSD 5215 and DSD 7215 manuals. This addendum documents the 
new tape functions in the expanded function set of the DSD 
5217 and the DSD 7217. These new tape functions are referred 
to as 217 tape functions, because they emulate the tape func- 
tion set of the Intel iSBX 217. This addendum must be used 
with a 5215 or a 7215 manual. 

Except for the presence of the 217 tape functions, the 
5217 is identical to the 5215, and the 7217 to the 7215. This 
addendum is limited to the programming information needed to 
implement the 217 tape functions. Consult the 5215 or 7215 
manual for: 

General Information 

Specifications 

Installation 

Programming Information for other Functions 

Controller Architecture 

User Level Maintenance 

Appendices 

For the 5217 and 7217 , section 4.4.1 of this addendum (Con- 
troller Invocation Block) replaces section 4.6.7 of the 5215 
and 7215 manuals, regardless of whether the 217 tape functions 
are implemented. 

The material in this manual is subject to change without 
notice. The manufacturer assumes no responsibility for any 
errors which may appear. 

please note that Intel, iSBX, Multibus and the combina- 
tion iSBX and a numerical suffix are registered trademarks of 
Intel Corporation. 
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4. Programming 



4.1. Introduction 

The DSD 5217 and the DSD 7217 are an enhanced versions of pre- 
vious Multibus controllers. In these units f the function set 
has been expanded to include an emulation of the tape function 
set of the Intel iSBX 217. These additional functions 
(referred to as 217 tape functions) supplement the existing 
function set. The DSD tape functions remain unaffected, and 
can be used with tape drive 0. 

4.2. Features 

The new features in the expanded function set are: 

• Support of an additional three streaming tape drives, for 
a total of four . 

• Support of file oriented data transfers, between host 
memory and tape. 

• Backup of selected records and files (onto blank 
tape) , in addition to the existing function for 
mirror-image backup of a disk. 

• Restoration of selected records and files to the 
disk, in addition to the existing function for 
mirror- image restoration of a disk. 

• Erase and rewind of tape cartridges can be done as a 
utility function. 
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4.3. New Functions 

The new functions transfer data between host memory and tape. 
Records or files on disk must be transferred to host memory 
before being written to tape. Restoration of data to disk 
requires a similar procedure. 

There are two types of 217 tape functions: short term and 
long term (see Table 4-1) . Short term functions generate one 
interrupt when they are complete. No other DSD functions are 
possible during a short term function. 

Long term functions generate an interrupt when they 
begin, and return control of the bus to the host. A second 
interrupt is generated when they finish. During a long term 
function, other functions (non-tape) may be issued. 

Table 4-1. 217 Tape Functions 



Function 


Hex 


L or S 


Sect. 


Fig. 


Page 


Initialize 


(00H) 


Short 


4.5.1 


4-3 


4-8 


Tape Initialization 


(10H) 


Short 


4.5.2 


4-4 


4-10 


Tape Reset 


(1CH) 


Short 


4.5.3 


4-5 


4-11 


Read Tape Status 


(1EH) 


Short 


4.6.1 


4-6 


4-13 


Transfer Status 


(01H) 


Short 


4.6.2 


4-7 


4-14 


Read Data 


(04H) 


Short 


4.7.1 


4-8 


4-18 


Write Data 


(06H) 


Short 


4.7.2 


4-9 


4-21 


Read/Write Terminate 


(1FH) 


Short 


4.7.3 


4-10 


4-23 


Forward One Record 


(1AH) 


Short 


4.7.4 


4-11 


4-24 


Forward One File 


(12H) 


Long 


4.7.5 


4-12 


4-26 


Write File Mark 


(14H) 


Short 


4.7.6 


4-13 


4-27 


Retension Tape 


(1DH) 


Long 


4.8.1 


4-14 


4-28 


Rewind Tape 


(HH) 


Long 


4.8.2 


4-15 


4-29 


Erase Tape 


(17H) 


Long 


4.8.3 


4-16 


4-30 



To use the 217 tape functions, a function sequence must 
be executed after power-up. The initialize function (00H) 
tells the DSD controller that tape drives are present. Not 
present is the default for all drives. Tape initialize (10H) 
and then tape reset (1CH) is required for each drive present. 
These functions are detailed in section 4.5, Power-Up Function 
Sequence. 

A set of error status messages for the 217 tape functions 
is accessed through the read tape status (1EH) and transfer 
status (01H) functions. These functions are detailed in sec- 
tion 4.6, Tape Status Functions. 

The 217 tape functions allow specific files and records 
to be read and written with the read (04H) and write (06H) 
data functions. There are functions to move the tape forward 
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one record (1AH) or one file (12H) , and to write a file mark 
(14H) . There is also a read/write terminate function (1FH) . 
These functions are detailed in section 4.7, 
Read/Write/Terminate Functions. 

The retension (1DH) , rewind (11H) , and erase (17H) func- 
tions are detailed in section 4.8, Utility Functions. 

4.4. Control Blocks 

The 217 tape functions use an additional control block (Tape 
Parameter Buffer) with the IOPB, as well as the five used pre- 
viously. 

Wake-Up Block (WUB) 

Channel Control Block (CCB) 

Controller Invocation Block (CIB) 

Input/Output Parameter Block (IOPB) 

Data Buffer: used with the IOPB 

Tape Parameter Buffer (TPB) : used with the IOPB 
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4.4.1. Controller Invocation Block (CIB) 

For the 5217 and the 7217, this section replaces section 4.6.7 
and Figure 4-6 of the 5215 and 7215 manuals. 

The DSD controller uses the CIB to post status to the 
host. Figure 4-1 shows the layout of the CIB in host memory, 
and Table 4-2 shows the function of each byte. 

Controller Invocation Block 
7 7 



1 


Operation 
Status 


Reserved* 





3 


Status 
Semaphore 


Command 
Semaphore 


2 


5 


00H 


4 


7 


00H 


6 


9 


IOPB Offset 


8 


11 


IOPB Segment 


10 


13 
15 


Reserved* 


12 
14 



* = set to zeros CCB points here — » 
Figure 4-1. Controller Invocation Block 
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Byte # 



Table 4-2. Controller Invocation Block 
Definition 



Reserved: set to zeros. 

1 Operation Status: This byte contains the most recent 

data transferred by a transfer 
status function. The status is 

Bit numbers: encoded bit- by-bit as shown. 



7 6 5-4 3 2 10 



S H 

u a 

m r 

m d 

m d 
a 
r 

y 



E 
r 
r 
o 
r 



U 
n 
i 
t 
t 

I 
D 



= 



1 = 

10 = 

11 = 

10 = 



10 1 
110 
111 
10 
10 1 

10 10 
10 11 
110 
110 1 
1110 

1111 



Winchester drive (reserved) , or DSD 

tape function (function codes 81H 

or 82H) . 

Winchester drive: immediate 

function complete. 

Winchester drive: seek complete. 

Winchester drive: reserved. 

Media change detected: Winchester 

drive, or tape drive during a DSD 

tape function. 

Winchester drive: reserved. 

Winchester drive: reserved. 

Winchester drive: reserved. 

Floppy drive: reserved. 

Floppy or tape drive: immediate 

function complete. 

Floppy drive: seek complete. 

Floppy drive: reserved. 

Floppy drive: media change detected, 

Floppy drive: reserved. 

Tape drive: media change detected. 

Tape drive: long term function 

completed. 



Command 
Semaphore: 



The controller does not use this byte 
It is provided as a multiprocessor 
interlock. 



Status The controller posts status only when 

Semaphore: this block is 00H. After posting new 

status, the controller sets this byte 
to FFH. After the host reads status, 
it should reset this byte to 00H. 
4-7 Set to zeros. 
8-11 Segmented IOPB address. 
12-15 Reserved: set to zeros. 
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4.4.2. Input/Output Parameter Block (IOPB ) 

There is an IOPB figure in each function section of this 
addendum. The shaded fields in each IOPB figure are the ones 
necessary for that function. The fields shaded include: 

• Device: 

When the hex code 04H is placed in this field, it indi- 
cates that a 217 tape function is being issued. 

• Function: 

The hex code placed in this field selects the next func- 
tion. 

• Unit: 

The value placed in this field selects the tape drive. 
The value may range between and 3. 

• Modifier: 

Bit 6 of this field (previously reserved) is used with 
the transfer status function. This bit selects the data 
to be returned by the transfer status function. The 
choices are: 

• A short term function, or the first interrupt of 
long term function, or 

• the second interrupt of a long term function. 

• Data Buffer Address: 

These fields are used with the Initialize function (00H) 
to point to a one-byte long tape parameter buffer. It is 
also used (as before) to point to addresses in host 
memory. 

• Requested Transfer Count: 

Used the same as for floppies and Winchesters. 
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7 
1 
3 
5 
7 

9 II 



Input/Output Parameter Block 
7 




Actual Transfer Count 
Returned at End 
of Operation 

Device = 04H 



<r 

2 

4 
6 

I 8 



11 M Function = 00H Ml Unit M 10 

"" """■ 12 

14 



Modifier 



| Cylinder 


i 


| Sector | Head | 


| Data Buffer Offset | 



13 n 

15 

17 

19 

21 

23 

25 

27 | 

29 | General Address Pointer Segment* 

* = set to zeros 7 

-^r;r* — — — — — — — <— — — — — — ■— — Tjrr 

Tape Parameter Buffer: j%$ TPB Si::] 



Data Buffer Segment 



I Requested Transfer Count jj 

I General Address Pointer Offset* I 



16 
18 
20 
22 
24 
26 
28 



•or 



Data Buffer: 
7 



7 

1 | Total Number of Cylinders 
3 | Removable Heads | Fixed Heads 
5 | Bytes/Sector (L) | Sectors/Track 
7 | # of Alt. Cyl. | Bytes/Sector (H) 







CIB points here 



Figure 4-2. Input/Output Parameter Block 
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4.5. Power-Up Sequence 

There are three functions that must be invoked in a power-up 
sequence: 

Initialize (00H) 

Tape Initialization (10H) 

Tape Reset (1CH) 

4.5.1. Initialize (00H ) 

Initialize (see Figure 4-3) is a short term function that 
informs the DSD controller that tape drives are present. Not 
present is the default for all drives. This function must be 
followed by the tape initialization (10H) function. 

The information transferred to the controller by this 

function is stored in an extension to the IOPB called the tape 

parameter buffer. The data buffer offset and segment stored 
in the IOPB are used to address the TPB. 

Only bit is used in the TPB. Bits 1 through 7 are not 
looked at by the controller. Present (bit 0=1) must be 
indicated in the TPB for each drive installed. Not present 
(bit 0=0) is the default for all drives. 
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Input/Output Parameter Block 
7 



1 

3 


Reserved* 


n t . » . 


u *■ 

2 
4 
6 


5 
7 


Actual. Transfer Count 
Returned at End 
of Operation 




9 


H Device = 04H 


H 8 


11 M Function = 00H STO Unit 


"H 10 


13 


Modifier 




12 
14 
16 


15 


Cylinder 




17 


Sector | Head 




19 |j$ Data Buffer Offset 


m 18 >-] 




21 |p Data Buffer Segment 


|| 20 >— 




23 
25 


Requested Transfer Count 




22 
24 
26 
28 

r 




27 


General Address pointer Offset* 




29 


General Address pointer Segment* 




* =s 


set to zeros 7 







e Parameter Buffer: ||| TPB** 


Tap 
CIB 


1 < 










Figure 4- 


3. Initialize (00H> 









•Programming Addendum for 217 Tape Functions- 



4-10 



4.5.2. Tape Initialization (10H ) 

Tape initialization (see Figure 4-4) is a short term function 
that allows the tape drive controller to set up its internal 
parameters. 



7 
1 
3 
5 
7 

^ m 



Input/Output Parameter Block 
7 



Reserved* 



Actual Transfer Count 
Returned at End 
of Operation 



"!w?~ — — — — — — — — — — — — — — — — -y&jpxr 

11 |§ Function = 10H |§|| 



13 
15 
17 
19 
21 
23 
25 
27 
29 



Device = 04H j$*| 

Unit §| 10 
12 
14 
16 
18 
20 
22 
24 
26 
28 



1 


Modifier | 


| Cylinder | 


| Sector 


| Head | 


| Data 


Buffer Offset | 


| Data 


Buffer Segment | 



Requested Transfer Count 



General Address pointer Offset* 
General Address Pointer Segment* 



* = set to zeros CIB points here 

Figure 4-4. Tape Initialization (10H ) 



This function must be invoked immediately after the 00H 
initialization function, and must be followed by the 1CH tape 
reset function. If the tape drive controller cannot complete 
a tape initialization function, bit 4 of byte in the error 
status buffer is set, 
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4.5.3. Tape Reset (1CH ) 

Tape reset (see Figure 4-5) is a short term function that 
invokes a tape drive controller reset procedure. This func- 
tion must be invoked after the tape initialization (10H) func- 
tion in the function sequence following power-up. 

Input/Output Parameter Block 
7 7 




Actual Transfer Count 
Returned at End 
of Operation 



iv3j 



9 £& Device = 04H >w 

mmajmmjmm on mi •"■ mm <«■ rm» *«* «■« mm mm nmi mm m» wim "'^IJI^^'^r" »"• ""■• ""* *■• ™* "• mm •"» "■• «■• mm *""• "™ <m*» *■■• MM«|^ik» 

11 H Function = 1CH |||§ Unit i| 10 



13 | 
15 | 
17 | 
19 | 
21 1 
23 
25 
27 
29 



Modifier 1 



Cylinder 
Sector | Head 
Data Buffer Offset 
Data Buffer Segment 




General Address Pointer Offset* 
General Address pointer Segment* 



12 
14 
16 
18 
20 
22 
24 
26 
28 



* * set to zeros 
Figure 4-5. Tape Reset (1CH) 



CIB points here 



■Programming Addendum for 217 Tape Functions- 



4-12 



4.6. Tape Status Functions 

There are two functions used to obtain tape status: 

Read Tape Status (1EH) 
Transfer Status (01H) 

Please note that these functions are normally invoked sequen- 
tially. Read tape status (1EH) transfers data to the 6217. 
Transfer status (01H) is required to move the data into host 
memory. 
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4.6.1. Read Tape Status (1EH ) 

Read tape status (see Figure 4-6) is a short term function 
that puts current tape status into the status buffer of the 
DSD controller. This function should be followed by a 
transfer status function (01H) . 



7 
1 
3 
5 
7 

* 1 



Input/Output Parameter Block 
7 



Reserved* 



Actual Transfer Count 
Returned at End 
of Operation 



Device = 04H 

%vv , ,— • — • — -~ "" — — — — — — — — <— — rrnrw r- — — — -»■— — — -• — - 

11 |:$ Function ~ 1EH j$lpvj Unit 

13 | Modifier 

15 | Cylinder 

17 | Sector | Head 

19 | Data Buffer Offset 

21 | Data Buffer Segment 

23 

25 

27 

29 




2 
4 
6 

j§ 8 
If 10 

■ i. V » V i« 

.-] 12 

""\ 14 




General Address pointer Offset* 
General Address pointer Segment* 



16 
18 
20 
22 
24 
26 
28 



* = set to zeros CIB points here 

Figure 4-6. Read Tape Status (1EH) 
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4.6.2. Transfer Status (01H ) 

Transfer status (see Figure 4-7) is a short term function used 
to read the error status buffer from the controller's internal 
memory. The read tape status (1EH) function must first be 
used to place information describing function status or error 
information in the internal buffer. 

The IOPB data buffer offset and segment specify the 
address in host memory where the data from the internal error 
status buffer are to be placed. 

The 12 byte error status buffer (see Table 4-3) may con- 
tain three types of data as selected by the IOPB modifier 
field. The buffer may contain data about the function or 
error status of: 

• The last short term function (modifier bit 6 a 0) , or 

• the last long term function at the time of the first 
interrupt (modifier bit 6 = 0) , or 

• current status of the last long term function (modifier 
bit 6 = 1). 

Because the error status buffer is cleared by the controller 
at the beginning of all other functions, desired information 
must be read before each new function is invoked. 
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Input/Output Parameter Block 
7 




Actual Transfer Count 
Returned at End 
of Operation 



5 
7 

» 1 

11 p Function =* 01H jig|| 
13 | Modifier 



Device = 04H 






Unit 




2 
4 
6 
I 8 

i 10 

I 12 



15 | 

17 r 

21 H 

23 

25 



Cylinder 



Sector 



Head 



14 
16 
18 



Data Buffer Offset J: vi 
Data Buffer Segment j£t| 20 



Requested Transfer Count 



22 
24 



27 | General Address pointer Offset* | 26 
29 | General Address Pointer Segment* | 28 

* = set to zeros CIB points here 

Figure 4-7. Transfer Status (01H) 
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Byte # 



Table 4-3. Error Status Buffer Definitions 
Definition 



Hard Error Byte 



End of tape (EOT) . 

Illegal format or device code, unit not 
present, or wrong unit. 

Long term function in progress when 
another function was issued. 

Failed tape initialization function. 

Not used. 

Tape drive function rejected by tape 
drive controller. 

217 tape function rejected by 6217. 

DSD tape function rejected by 6217. 



Tape cartridge write protected. 

Selected unit not ready. 

Invalid address. 

No tape cartridge in selected drive. 

Invalid function as defined by byte 0, 
bit 0, 1, or 2. 

Timeout occurred on tape function. 

Diagnostic fault. 

Length error: 

o No transfers requested, or 

o requested transfer count not divisible 

by 512, or 
o read or write function terminated as 

specified by other bytes. 

(Continued) 
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Table 4-3. Error Status Buffer Definitions (continued) 



Byte # 



Definition 



3 

4 

5 
6, 7 

8 
9, 10 
11 



Soft Error Byte 



Bit: 



Not used. 

Buffer over/under run: no data lost, but 
tape drive controller had to stop tape, 
rewind slightly, and bring tape up to 
speed before continuing. 

Broken tape or other drive fault. 

Not used. 

Unrecoverable data detected on tape. 

Not used. 

Recoverable data error: function 
completed through the use of retries. 

Not used. 



Beginning of tape (BOT) , FFH = true. 
Not used. 

File mark detected (FMD) , FFH = true. 
Not used. 

No data detected, FFH = true. 
Not used. 

Number of retries. 
Byte value: 



1 
8 

16 



Less than 8 . 

Between 8 and 16: indicates probable 
media wear. 

Unrecoverable data: indicates media 
probably worn out. 
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4.7. Read/Write/Terminate Functions 

There are six functions grouped in this section: 

Read Data (04H) 
Write Data (06H) 
Read/Write Terminate (1FH) 
Move Forward One Record (12H) 
Move Forward One File (12H) 
Write File Mark (14H) 



4.7.1. Read Data (04H ) 

Read data (see Figure 4-8) is a short term function that 
transfers data from the tape drive to a host memory buffer 
The IOPB unit field specifies the drive to be accessed. 

Input/Output Parameter Block 
7 7 




Actual Transfer Count 
Returned at End 
of Operation 



|| Device = 04H %| 

11 I! Function = 04H $||§ Unit || 
13 | Modifier | 12 




2 
4 
6 
8 
10 



15 | 
17 | 



Cylinder 



Sector 



Head 



14 
16 



19 §! Data Buffer Offset || 18 

21 ||j| Data Buffer Segment gj:$ 20 



23 
25 
27 
29 



■ ■ v ~~" — ■"-"■ — — — — — -• — — — — 

I Requested Transfer Count 

General Address pointer Offset* 
General Address pointer Segment* 



•:•:•:•» 



22 
24 
26 
28 



* = set to zeros 
Figure 4-8. Read Data (04H) 



CIB points here 
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The IOPB data buffer offset and segment specify the 
address of the buffer in host memory. Bytes are transferred 
consecutively from the on-board buffer to the sequentially 
accessed host memory. 

The controller clears the actual transfer count field in 
the IOPB at the beginning of this function. The requested 
transfer count is placed in the IOPB for the controller to 
read. It must be divisible by 512. 

If the data transfer rate falls below 200 Kb/sec during 
the read data function, the streaming mode cannot be main- 
tained. In such a case, a buffer over/underrun error is 
posted to indicate that the tape drive controller had to stop 
and reposition the tape, and then continue the read data func- 
tion. This is not an indication of bad data. 



This function continues until one of three conditions is met: 

• The actual transfer count equals the requested transfer 
count, or 

• a file mark is encountered on the tape, or 

• a Read/Write terminate function is encountered. 

If the buffer area in host memory is too small to accommodate 
an entire file, it may be necessary to use a series of read 
data functions with small transfer counts. If the actual 
transfer count equals the requested transfer count before a 
file mark is encountered, a transfer status function would 
reveal a buffer over/underrun error. 

If the actual transfer count equals the requested 
transfer count shortly before a file mark is encountered, a 
transfer status function does not return file mark status, 
because this value is not written until the next read data 
function is issued. 

When the read data function continues until it is ter- 
minated by a file mark on the tape, the controller writes 89H 
in the operation status byte of the controller invocation 
block. 89H in the operation status byte indicates a tape 
drive summary error, and termination of the function. 

If a transfer status function reveals the file mark byte 
and the length error bit set, this should be interpreted as a 
successful termination. This is a legal termination pro- 
cedure, although it does use what are otherwise error messages 
to indicate a successful completion. 

A read data function still in progress can be terminated 
by a read/write terminate function. A Read/Write terminate 
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function is legal only before the read data function ter- 
minates for other reasons. 

When a read data function is terminated by a read/write 
function, it causes the drive to stop reading data and rewind 
to the BOT. In the error status buffer, this function posts a 
buffer over/under run error, and sets the BOT byte. The 
over/under run error does not indicate bad data. 

If the tape drive controller detects bad data, it makes a 
maximum of 16 attempts to read the data. This action is tran- 
sparent to the DSD controller and the host. 

If the data is successfully read, byte 11 of the error 
status buffer indicates that retries were necessary, with an 
approximation of how many. A byte value of 1 indicates that 
less than seven retries were necessary. A byte value of 8 
indicates that between 8 and 16 retries were necessary. 

If the data cannot be read in 16 automatic attempts, an 
unrecoverable data error is posted. The value 16 is posted to 
byte 11. 

A read data function issued on a blank tape will ter- 
minate after a few inches of tape have been accessed. These 
errors post: 

• Length 

• Recoverable data 

• Unrecoverable data 

• No data detected 



•Programming Addendum for 217 Tape Functions- 



4-21 



4.7.2. Write Data (06H ) 

The write data function (see Figure 4-9) is a short term func- 
tion that transfers data from a host memory buffer to a tape 
drive. The IOPB unit field specifies the drive to be 
accessed. 
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Figure 4-9. Write Data (06H) 



CIB points here- 



The IOPB data buffer offset and segment specify the 
address of a buffer in host memory. The host memory is 
sequentially accessed. Bytes are transferred consecutively 
into the on-board buffer and then written to the tape. 

The controller clears the actual transfer count field in 
the IOPB at the beginning of this function. The requested 
transfer count is placed in the IOPB for the controller to 
read. It must be divisible by 512. 
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This function continues until the actual transfer count 
equals the requested transfer count, or a read/write terminate 
function is encountered. 

If the buffer area in host memory is too small to accom- 
modate an entire file, it may be necessary to use a series of 
write data functions with small transfer counts, until the 
entire file has been transferred. The series of write data 
functions must be terminated by an Archive read/write ter- 
minate function. A read/write terminate function is legal 
only before the write data function terminates for other rea- 
sons. 

When a write data function is terminated by a read/write 
function, it causes the drive to stop writing data, write a 
file mark, and then rewind to BOT. In the error status 
buffer, this function posts a buffer over/underrun error, and 
sets the BOT byte. The over/underrun error does not indicate 
bad data. 

If the tape drive controller detects bad data, it makes a 
maximum of 16 attempts to write the data. This action is 
transparent to the DSD controller and the host. 

If the data is successfully written, byte 11 of the error 
status buffer indicates that retries were necessary, with an 
approximation of how many. A byte value of 1 indicates that 
less than seven retries were necessary. A byte value of 8 
indicates that between 8 and 16 retries were necessary. 

If the data cannot be written in the 16 automatic 
attempts, an unrecoverable data error is posted. The value 16 
is posted to byte 11. 

If the data transfer rate falls below 200 Kb/sec during 
the write function, the streaming mode cannot be maintained. 
In such a case, a buffer over/underrun error is posted to 
indicate that the tape drive controller had to stop and rewind 
the tape, and bring it up to speed before continuing the write 
data function. 
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4.7.3. Read/Write Terminate (1FH ) 

The read/write terminate (see Figure 4-10) function terminates 
a read or write function in progress. This function is legal 
only before a read or write function terminates for other rea- 
sons. 

This function causes the drive to stop reading data and 
rewind to BOT. If the function being terminated by the 
read/write termination was write data (06H) , a f ilemark is 
automatically written before the tape rewinds. 

In the error status buffer, this function posts a buffer 
over/underrun error and sets the BOT byte. The over/under run 
error does not indicate bad data. 
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Figure 4-10. Read/Write Terminate (1FH) 
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4.7.4. Move Forward One Record (1AH ) 

Move forward one record (see Figure 4-11) is a short term 
function that moves the tape forward seeking an interblock 

gap. 

The function terminates when one of four conditions is met: 

• An interblock gap is encountered, or 

• a file mark is detected (FMD bit set in error status 
buffer) , or 

• the end of tape is encountered (EOT bit set in error 
status buffer) , or 

• the function times out on a blank tape (time-out bit 
set) . 

Time out occurs after the time needed for 32 data blocks to 
pass has elapsed. 
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Figure 4-11. Move Forward One Record (1AH) 
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4.7.5. Move Forward One File (12H ) 

Move forward one file (see Figure 4-12) is a long term func- 
tion that causes the tape to advance until a file mark is 
encountered, or the end of media is reached. When a file mark 
has been found, the FMD bit is set in the error status buffer. 
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4.7.6. Write File Mark (14H ) 

Write file mark (see Figure 4-13) is a short term function 
that writes a file mark on the tape. The IOPB function field 
value for this function is 14H. The value in the unit field 
can range from to 3. 
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Figure 4-13. Write File Mark (14H) 
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4.8. Utility Functions 

Retension, rewind, and erase tape are offered as utility func- 
tions. 

4.8.1. Retension Tape (1DH ) 

Retension tape (see Figure 4-14) is a long term function that 
causes the tape to fast forward to EOT and then rewind to BOT. 
This function attempts to improve the condition of the tape in 
the cartridge. 
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Figure 4-14. Retension Tape (1DH) 
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4.8.2. Rewind Tape (11H ) 

Rewind tape (see Figure 4-15) is a long term function used to 

place the tape in a known position. This is done by rewinding 

the tape to BOT position and setting the BOT bit in the status 
buffer . 




7 
1 
3 
5 
7 

' I 



Input/Output Parameter Block 
7 



Actual Transfer Count 
Returned at End 
of Operation 

Device =* 04H 



i 



11 JH Function =■■ 11H |||| Unit §| 10 

13 | Modifier 

15 | Cylinder 

17 | Sector | Head 

19 | Data Buffer Offset 

21 | Data Buffer Segment 

23 

25 

27 | General Address pointer Offset* 

29 | General Address pointer Segment* | 

* = set to zeros CIB points here 

Figure 4-15. Rewind Tape (11H) 
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4.8.3. Erase Tape (17H ) 

Erase tape (see Figure 4-16) is a long term function that 
moves the tape to BOT r erases until EOT is reached, and then 
rewinds the tape to BOT again. 

Input/Output Parameter Block 
7 7 



1 

3 


Reserved* 


«—i 

2 

4 

6 

8 

10 

" 12 

14 

16 

18 

20 

22 

24 

| 26 

| 28 


5 Actual Transfer Count 

Returned at End 
7 of Operation 

9 j$$ Device = 04H 

11 ll Function = 17H |||| Unit 

13 | Modifier 


1 

i 


15 


Cylinder 




17 


Sector | Head 




19 


Data Buffer Offset 




21 


Data Buffer Segment 




23 
25 


Requested Transfer Count 


27 


General Address pointer Offset* 




29 


General Address pointer Segment* 


ay t 


* _ 


„«♦. +. rt -«v/^r< r>Ta Y"\»~» -1 r» *> Q V\ 



Figure 4-16. Erase Tape (17H) 
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